

## Claims

[c1] A method for optimizing placement of redundant vias within an integrated circuit design, said method comprising:

- a) locating target vias;
- b) drawing marker shapes adjacent to said target vias in a first direction;
- c) using an optimizer to simultaneously expand all of said marker shapes either in said first direction, wherein during said expanding, different marker shapes will be expanded to different lengths;
- d) determining which of said marker shapes were expanded sufficiently to form a valid redundant via to produce a first set of potential redundant vias;
- e) eliminating marker shapes that could not be expanded sufficiently to form a valid redundant via; and
- f) repeating steps b–e in a second direction perpendicular to said first direction to produce a second set of potential redundant vias.

[c2] The method in claim 1, wherein said locating of said target vias and said drawing of said marker shapes is performed using a shapes-processing program.

- [c3] The method in claim 1, wherein said expanding of said marker shapes is performed using a minimum perturbation layout-migration tool based on augmented ground rules.
- [c4] The method in claim 3, wherein said augmented ground rules direct said layout-migration tool how to modify said marker shapes to reveal when space is available to continue said expanding of said marker shapes.
- [c5] The method in claim 1, wherein said determining which of said marker shapes were expanded sufficiently is performed using a shapes-processing program.
- [c6] The method in claim 1, wherein said integrated circuit design complies with design ground rules prior to step a.
- [c7] The method in claim 1, further comprising after step f, adding redundant vias to said integrated circuit design according to output produced by said optimizer.
- [c8] A method for optimizing placement of redundant vias within an integrated circuit design, said method comprising:
  - a) locating target vias by determining which vias do not have a redundant via;
  - b) drawing marker shapes adjacent said target vias,

wherein said marker shapes are drawn in a first direction;

c) using an optimizer to simultaneously expand all of said marker shapes in said first direction for a predetermined length or until said marker shapes reach the limits of a ground rule, wherein during said expanding, different marker shapes will be expanded to different lengths;

d) determining which of said marker shapes were expanded sufficiently to form a valid redundant via to produce a first set of potential redundant vias;

e) eliminating marker shapes that could not be expanded sufficiently to form a valid redundant via; and

f) repeating steps b-e in a second direction perpendicular to said first direction to produce a second set of potential redundant vias.

- [c9] The method in claim 8, wherein said locating of said target vias and said drawing of said marker shapes is performed using a shapes-processing program.
- [c10] The method in claim 8, wherein said expanding of said marker shapes is performed using a minimum perturbation layout-migration tool based on augmented ground rules.
- [c11] The method in claim 10, wherein said augmented

ground rules direct said layout-migration tool how to modify said marker shapes to reveal when space is available to continue said expanding of said marker shapes.

- [c12] The method in claim 8, wherein said determining which of said marker shapes were expanded sufficiently is performed using a shapes-processing program.
- [c13] The method in claim 8, wherein said integrated circuit design complies with design ground rules prior to step a.
- [c14] The method in claim 8, further comprising after step f, adding redundant vias to said integrated circuit design according to output produced by said optimizer.
- [c15] A method for optimizing replacement of stacked vias within an integrated circuit design, said method comprising:
  - a) locating stacked vias by determining which vias are positioned above or below vias in adjacent wiring levels of said integrated circuit design;
  - b) drawing marker shapes on or adjacent to said stacked vias in a first direction;
  - c) using an optimizer to simultaneously expand all of said marker shapes in said first direction for a predetermined length or until said marker shapes reach the limits of a ground rule, wherein during said ex-

panding, different marker shapes will be expanded to different lengths;

d) determining which of said marker shapes were expanded sufficiently to form a valid replacement via to produce a first set of potential replacement vias;

e) eliminating marker shapes that could not be expanded sufficiently to form a valid replacement via;

f) repeating steps b-e in a second direction perpendicular to said first direction to produce a second set of potential replacement vias; and

g) replacing said stacked vias with said first set of potential replacement vias and said second set of potential replacement vias by removing said stacked vias from said integrated circuit design and adding said first set of potential replacement vias and said second set of potential replacement vias to said integrated circuit design.

[c16] The method in claim 15, wherein said locating of said stacked vias and said drawing of said marker shapes is performed using a shapes-processing program.

[c17] The method in claim 15, wherein said expanding of said marker shapes is performed using a minimum perturbation layout-migration tool based on augmented ground rules.

- [c18] The method in claim 10, wherein said augmented ground rules direct said layout-migration tool how to modify said marker shapes to reveal when space is available to continue said expanding of said marker shapes.
- [c19] The method in claim 15, wherein said determining which of said marker shapes were expanded sufficiently is performed using a shapes-processing program.
- [c20] The method in claim 15, wherein said integrated circuit design complies with design ground rules prior to step a.
- [c21] A program storage device readable by machine, tangibly embodying a program of instructions executable by the machine to perform a method for optimizing placement of redundant vias within an integrated circuit design, said method comprising:
  - a) locating target vias;
  - b) drawing marker shapes adjacent to said target vias in a first direction;
  - c) using an optimizer to simultaneously expand all of said marker shapes either in said first direction, wherein during said expanding, different marker shapes will be expanded to different lengths;
  - d) determining which of said marker shapes were expanded sufficiently to form a valid redundant via to produce a first set of potential redundant vias;

e) eliminating marker shapes that could not be expanded sufficiently to form a valid redundant via; and  
f) repeating steps b–e in a second direction perpendicular to said first direction to produce a second set of potential redundant vias.

- [c22] The program storage device in claim 21, wherein said locating of said target vias and said drawing of said marker shapes is performed using a shapes–processing program.
- [c23] The program storage device in claim 21, wherein said expanding of said marker shapes is performed using a minimum perturbation layout–migration tool based on augmented ground rules.
- [c24] The program storage device in claim 23, wherein said augmented ground rules direct said layout–migration tool how to modify said marker shapes to reveal when space is available to continue said expanding of said marker shapes.
- [c25] The program storage device in claim 21, wherein said determining which of said marker shapes were expanded sufficiently is performed using a shapes–processing program.
- [c26] The program storage device in claim 21, wherein said in-

tegrated circuit design complies with design ground rules prior to step a.

- [c27] The program storage device in claim 21, wherein said method further comprises after step f, adding redundant vias to said integrated circuit design according to output produced by said optimizer.